package com.rui.study.algorithm.SORT_3_选择排序;

/**
 * @program: study
 * @description:
 * @author: Yaowr
 * @create: 2018-11-07 10:15
 **/
public class SelectionSort {

    /**
     * 选择排序：每次将未排序区间的最小元素，放置在已排序区间的末尾
     * 最好时间复杂度：O(n²)
     * 最坏时间复杂度：O(n²)
     * 空间复杂度：O(1)
     * 稳定性：不稳定
     * @param a
     */
    public static void sort(int[] a) {
        for (int i=0; i<a.length; i++) {
            int idx = i;      // 寻找最小值的索引
            for (int j=i+1; j<a.length; j++) {
                if (a[j] < a[idx]) {
                    idx = j;
                }
            }
            if (i != idx) {
                a[i] += a[idx];
                a[idx] = a[i] - a[idx];
                a[i] = a[i] - a[idx];
            }
        }
    }
}
